<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>vue的封装的过渡</title>
    <style>
        .picture {
            width: 100px;
        }

        /* 离开的起点 来的起点*/
        .cool-leave, .cool-enter-to {
            opacity: 1;
            transform: scale(1) rotate(0deg);
        }
    /*    离开的终点 来的起点*/
        .cool-leave-to,.cool-enter{
            opacity: 0;
            transform: scale(0) rotate(180deg);
        }
    /*    离开 来的具体的过渡规则*/
        .cool-leave-active,.cool-enter-active{
            transition: 1s all linear;
        }
    </style>
    <script src="js/vue.js"></script>
</head>
<body>
<!--
过渡
    1.在目标元素外包裹<transition name="xxx">
    2.编写样式：
        进入：
            进入起始点(xxx-enter)、
            进入过程中(xxx-enter-active)、
            进入结束点 的样式(xxx-enter-to)
        离开:
            离开起始点(xxx-leave)、
            离开过程中(xxx-leave-active)、
            离开结束点 的样式(xxx-leave-to)
-->
<div id="root">
    <button @click="isShow=!isShow">切换</button>
    <br><br>
    <transition name="cool">
        <img v-if="isShow" src="https://s3.ax1x.com/2020/12/13/reCaqg.jpg" class="picture">
    </transition>

</div>
<script type="text/javascript">
    Vue.config.productionTip = false//禁止提示生产提示
    new Vue({
        el: "#root",
        data: {
            isShow: true
        }
    })
</script>
</body>
</html>